# Timing Controller using FPGA MicroBlaze for a Digital Radar Receiver

Ragimol, Shajahan M

**Abstract**— With the popular hardware description languages in place, there is a wide range of options that enables Field Programmable Gate Array (FPGA) designers to design optimized hardware implementation adding to the flexibility that language-based design provides the designers. Designers get to implement flexible Intellectual Property (IP) core which is widely used for custom applications. Configurable soft processor cores that can be synthesized onto their FPGA products thus enhancing configurability and programmability are being manufactured by different vendors to suit the needs of front end users. The FPGA embedded processors use general-purpose FPGA logic to construct internal memory, processor buses, internal and external peripherals. This paper focuses on the design of a timing control and signal generation controller on Xilinx MicroBlaze for a digital radar receiver. MicroBlaze enhances critical timing algorithms important for radar communications with adequate advantages such as customization, flexibility, hardware acceleration, obsolescence mitigation and programmability with scalability. The processor environment in the FPGA fabric is utilized for providing customization of the timing unit for signal transmission. With the selection of an appropriate FPGA family, optimized hardware with high DMIPS benchmarks can be availed.

**Index Terms**— digital radar communications, FPGA, Microblaze, soft core processors, radar receiver, timing control and signal generation, Xilinx platform studio (XPS).

\_ \_ \_ \_ \_ \_ \_ \_ \_ \_ \_

# **1** INTRODUCTION

**A** *T***ITH the progressive increase in the use of FPGAs for** prototyping the embedded systems on a chip, the use of IPs is being used enhance the features of designs. To attach an IP with one of the buses in the design, the designer has to create an interface for it, for which so as to ease this task, FPGA vendors provide the facility for automatic generation of interfaces for custom IPs. Soft core processor Micro-Blaze, provided by Xilinx, is one such provision. As FPGA devices progresses both in terms of resources and performance, the latest FPGAs provides solutions that are easily customizable for system connectivity, DSP, and data processing applications. This helps leading FPGA vendors to come up with easy to use design development tools. There is an accelerated time-to-market delivery by automating the system definition and integration phases of system on programmable chip development [1]. Designers are provided the facility to quickly create hardware circuits, with increases in FPGA configurable logic capacity. FPGAs with soft processor cores provide designers with increased flexibility and scalability thus expanding the usefulness of soft processor cores on FPGAs to a broader range of applications.

Today FPGAs are used to quickly create efficient hardware designs, for which systems require a combination of both software and hardware. In earlier years, single-chip microprocessor/FPGA devices had been introduced [1]. These devices

 Ragimol is currently working as Assistant Professor in Department of Electronics and Communication Engineering in Sree Buddha College of Engineering, Kerala, India.
 E-mail: raginair1@gmail.com

 Shajahan M is a Scientist/Engineer in Space Physics Laboratory inVikram Sarabhai Space Centre, Thiruvananthapuram, Kerala, India. E-mail: m\_shajahan@vssc.gov.in include one or more hard-core microprocessors, implemented using transistors and an FPGA fabric on a single IC. Singlechip hard-core microprocessor/FPGA platforms offer excellent packaging and communication advantages, but a soft core approach offers the advantage of flexibility and lower part costs. FPGA vendors are now offering such soft processor cores that designers can implement using a standard FPGA. Altera offers both the NIOS and NIOS II soft processor cores [2]. The NIOS II processor is a 32-bit configurable processor supporting clock frequency as high as 135MHz. Xilinx offers the PicoBlaze and MicroBlaze soft processor cores. The Micro-Blaze processor is a 32-bit configurable processor core capable of supporting clock frequencies up to 150MHz. These soft processor cores offer designers tremendous flexibility during the design process, allowing the designers to configure the processor to meets the needs of their systems and to quickly integrate the processor within any FPGA. Selecting a soft processor core is a complex task with far-reaching design effects. The most important FPGA soft processor core selection factors include the cost of implementation, power consumption, operational performance, debug options, operating system considerations and the design and development tools needed. Soft processor cores allow designers to incorporate varying numbers of processors within a single FPGA design depending on an application's needs.

## **2 OVERVIEW OF THE DIGITAL RADAR RECEIVER**

Radar technology is on the verge of digital revolution since they are programmable, deterministic, and cheaper and require less maintenance and is easier to work with and has had a profound impact on the way radar systems are designed [3]. Advances in ADC and DAC technologies are pushing the border between analog and digital processing closer and closer to the antenna. Digital Radar Receiver in Field Programmable

Gate Array (FPGA) is crucial in accessing the behaviour of electro jets and wind currents at an altitude range of 80-110 km above the earth's surface. The digital receiver design consists of functional blocks namely Timing Control and Signal Generation, Signal Generation and Digital down conversion, Signal Processing Module, GUI & Data Storage Interfacing inclusive of ADC & DAC Interfacing. The present functionality is surpassed by incorporating MicroBlaze into the radar system. There is a fast register access by using the MicroBlaze, it relies on the commonly available fast block RAM in Spartan and Virtex FPGA devices and features a user-definable amount of zero-wait state block RAM, with true dual-port access. The OpenBUS wrappers can be implemented in any FPGA and allow the designer to implement FPGA-based portable cores. Xilinx FPGA technology allows customizing the hardware logic in processor subsystem. Such customization is not possible using standard off-the-shelf microprocessor or controller chips. The term "Hardware platform" describes the flexible, embedded processing subsystem created with Xilinx technology for application needs.

#### 2.1 Timing Control and Signal Generation Controller

The Timing Control and Signal Generation controller of the digital radar receiver is eventually designed and developed to control the whole synchronization of the radar receiver from a master clock for maintaining coherency. It generates the clock pulses and control signals necessary for the operation of the system, including the radar sample clock, the pulse repetition frequency, pulse width etc. It also deals with the overall system design considerations for developing the timing and control unit. The entire radar receiver is controlled by the timing radar controller block which stores the different configurations supported and issues correct timing control signals at the transmit and receive phases. The radar settings are entered into timing control module in FPGA at run time. The unit is designed to generate the control signals necessary for the operation of system parameters like the T/R pulse, TX signal, window starts at pulse etc. The timing process generates the pulsed RF which is transmitted from the exciter at a pulse width of 20µs, 60µs, 80µs or100 µs, selected using a GUI interface by the user. The on board ADC samples the received echoes at a height of 540µs for Zenith and 640µs for East -West of Zenith, corresponding to the height of the electro jets (80-110km). Depending on the range gates (typically 16) the samples are taken at intervals corresponding to the respective heights chosen. This continues for N number of windows wherein the FFT of the Doppler shifted data is taken and used for weather study. The FFT unit is enabled as and when the received samples are captured at the 'window starts at' pulse which in turn gets enabled once the transmission stops and reception process begins.

The Finite State Machine (FSM) of state type coding in VHDL has been designed to enable the inputs of the controller namely the pulse width, beam select pulse, number of range gates and number of FFT points. The outputs correspond to beam orientation, number of FFT points, the TR pulse and TX pulse. The pulse width enables the transmission of pulses on an average of 20-200.The user can select the beam select pulse to

correspond to either the Zenith position or E-W of Zenith. Accordingly the pulse being transmitted changes its position. The next input parameter being configured in the system is the number of range gates which can be manipulated by the user to 16, 32 or 64 whereby the data collects at respective height intervals. The FFT block determines the spectrum at runtime. The TR pulse corresponds to a reference pulse of 200µs which is used for determining the TX pulse which is the transmitted signal. This also determines the pulse repetition frequency which is analysed in due accordance with the window starts at pulse and the width of the reception window. The state types for the VHDL code contains timers corresponding to window starts at time, no of range gates, width of the reception window and the pulse repetition frequency.

# 3 TIMING CONTROL AND SIGNAL GENERATION CONTROLLER IN MICROBLAZE

The timing controller hardware module is better structured and modularized through the soft core processor MicroBlaze that helps to instantiate the input-output components and set the corresponding parameters using the Embedded Development Kit platform. XPS is used to develop Xilinx Embedded Development Kit (EDK) based system designs and provides an integrated hardware/software development environment. EDK is a series of software tools for designing embedded processor systems on programmable logic, and supports the IBM PowerPC hard processor core and the Xilinx MicroBlaze soft processor core. EDK helps to build hardware and a software platform, thus every component/part of the hardware modules becomes more independent and loosely coupled. Therefore, debugging and optimization of each component separately is made possible. This leverages the higher level of design reuse and simplified designs possible capable of updates thus increasing design modularization.

MicroBlaze is a 32-bit RISC machine that follows the classic RISC architecture. It is a load/store machine with 32 general purpose registers. All instructions are 32-bits wide and most execute in a single clock cycle. The backbone of the architecture is a single-issue, 3-stage pipeline with an Arithmetic Logic Unit (ALU), a shift unit, and two levels of interrupt. This basic design can then be configured with more advanced features to tailor to the exact needs of the target embedded application such as: barrel shifter, divider, multiplier, single precision floating-point unit (FPU), instruction and data caches, exception handling, debug logic, Fast Simplex Link (FSL) interfaces and others. This flexibility allows the user to balance the required performance of the target application against the logic area cost of the soft processor. The range of resources required to implement a MicroBlaze soft processor is between 900 and 2,600 Xilinx Look-Up Tables (LUTs), depending on how the processor is configured [5]. The BSB helps user to create the timing control peripheral which incorporates the timing control inputs and outputs.

The generated block diagram image is as shown in Figure 1.The timing input/output parameters information are stored in Microprocessor Project (XMP), Microprocessor Hardware

Specification (MHS) file and Microprocessor Software Specification (MSS).The XMP file stores the top-level information of the timing parameters, as shown in Figure 2 which shows the snapshot of the ISE ProjNav after configuring the system assembly view in XPS. It points the location of the MHS, MSS file, and the C/C++ program codes are compiled into an executable file for the timing peripheral. MHS file defines all hardware components in a platform.



## Fig 1: Block Diagram image of the Timing Control and Signal Generation unit

The sample MHS file for the timing controller IP is shown below:

#### //block of mhs file

BEGIN timing\_peripheral\_axi PARAMETER INSTANCE = timing\_peripheral\_axi\_0 PARAMETER HW\_VER = 1.00.a PARAMETER C\_BASEADDR = 0x73600000 PARAMETER C\_HIGHADDR = 0x7360ffff BUS\_INTERFACE S\_AXI = axi4lite\_0 PORT S\_AXI\_ACLK = clk\_100\_0000MHz PORT dip\_pw\_bs\_rg\_fft = timing\_peripheral\_axi\_0\_dip\_pw\_bs\_rg\_fft PORT led\_bo\_fft\_tr\_tx = timing\_peripheral\_axi\_0\_led\_bo\_fft\_tr\_tx END //block of mss file

```
BEGIN DRIVER
PARAMETER DRIVER_NAME = generic
PARAMETER DRIVER_VER = 1.00.a
PARAMETER HW_INSTANCE =
timing_peripheral_axi_0
END
```

EDK uses Intellectual-Property Interface (IPIF) library to implement common functionality among various processor peripherals. It is verified, optimized and highly parameterizeable. It also gives a set of simplified bus protocol called IP Interconnect (IPIC), which is much easier to use rather than operate on OPB or PLB bus protocol directly. The flow utilizes the ISE toolset to synthesize and implement (place and route) the soft processor and associated peripherals. The ML605 development board with Virtex6 FPGA is configured via user constraints file for the timing control specifications, as needed for the HF digital radar receiver. The MicroBlaze processor with a clock frequency of 100 MHz on an AXI bus ensures the timing operation by modifying the auto generated MPD and PAO files included in the PCORES directory. The PCORES contains the vhdl/custom\_logic.vhd which is the template file for the timing peripheral top design entity. It configures and instantiates the corresponding IPIF unit hooks it up to the stub user logic where the timing control functionality is implemented. The vhdl/user\_logic.vhd which is the template file for the stub user logic design entity, either in VHDL or Verilog, implements the timing control finite state machine. The user logic instantiates and focuses on the manipulation of slave registers to compile the data parameters of the timing module. The two 32-bit slave registers of MicroBlaze are modified for the read and write operation with the temp signals inside the file so as to overshadow the multiple source bus drivers problem commonly found in MicroBlaze systems.



Fig 2: ProjNav snapshot for configuration of timing peripheral

Software Development Kit (SDK) provides a development environment for software application projects. It provides a GUI interface to generate linker scripts for software applications, program FPGA devices, and program parallel flash memory. The system suite includes these FPGA design tools and the SDK environment which is an Eclipse-based implementation that supports efficient standardized software development and debug. The interaction between EDK and SDK justifies constitutes a co-design environment, but a different approach. To alleviate the performance and power overhead, a designer can potentially use hardware/software partitioning to increase software performance while decreasing energy [4]. The hardware platform created for the timing IP is imported into SDK prior to creation of software application and BSP for it. The SDK C/C++ program has been written to display the inputs and outputs for the timing peripheral, whereby the slave register reads the inputs configured from the ML605 development board namely the user input pulse width of the transmitted signal, the beam select position the number of range gates to specify the sampling bins and the number of FFT points to determine the spectrum. These values determine the outputs observed from the slave register1 offset where the window starts at parameter determines the start of reception judged by the output beam orientation, the TR pulse which is the reference signal of 200µs, the transmitted TX signal of corresponding pulse width and the FFT points are activated when the Doppler shifted signal arrives with information of the electro jets heights (determined by the Doppler frequency).

Figure 3 shows the ports configured for the timing and signal generation controller.



**Fig 3: Port Configurations** 

The software driver file timing\_peripheral.h defines the software driver header template file, which contains address offset of software addressable registers slv\_reg0 and slv\_reg1 in the peripheral, as well as some common masks and simple register access macros or function declaration. The timing\_peripheral.c shows the software driver source template file, to define all applicable driver functions. The timing\_peripheral\_selftest.c contains the self-test example code to test various hardware features of the timing peripheral. The header file, "xparameters.h" holds parameters for the embedded system.

/\* Definitions for peripheral TIMING\_PERIPHERAL\_AXI\_0 \*/

#define XPAR\_TIMING\_PERIPHERAL\_AXI\_0\_BASEADDR 0x73600000 #define XPAR\_TIMING\_PERIPHERAL\_AXI\_0\_HIGHADDR 0x7360FFFF

These parameters are referred to by the application code software, written in C/C++ language, to be able to communicate with the devices in the timing controller IP. The parameter of the base address of timing peripheral is determined as such from this header file. The slave registers are read to and written to in accordance with the specified register offsets, as shown in Figure 4.



Fig 4: SDK environment using the C/C++ environment

TIMING\_PERIPHERAL\_AXI\_mReadReg (XPAR\_TIMING\_PERIPHERAL\_AXI\_0\_BASEADDR, TIMING\_PERIPHERAL\_AXI\_SLV\_REG0\_OFFSET); TIMING\_PERIPHERAL\_AXI\_mReadReg (XPAR\_TIMING\_PERIPHERAL\_AXI\_0\_BASEADDR, TIMING\_PERIPHERAL\_AXI\_SLV\_REG1\_OFFSET);

IJSER © 2013 http://www.ijser.org

The software and soft processor core implementation tools are responsible for the parameterization of the soft core and associated peripherals and the implementation of processor buses, memory maps, interrupt structures and required processor peripherals. The software tools also include traditional compilation, linking, debug and download to the target processor. The embedded designs on 32 bit processors include OS and any lower-level software required to connect the OS to the hardware to reduce the design time through the board support package. EDK simulation is accomplished by exporting VHDL or Verilog HDL models of the embedded hardware platform design. The models include block RAM (BRAM) memory peripherals that one can initialize with our embedded software ELF file. Verification through behavioural, structural, and timing simulation can be performed at specific points in our design process[6]. The timing peripheral IP of the timing control and signal generation controller is set up in the simulation environment, added with test bench file, and Xilinx ISim is used to simulate the system. The user logic ports are imported into the wave environment and simulated with 10ns corresponding to the processor clock frequency of 100 MHz which is shown in Figure 5.

In order to compare the relative performance of soft processor cores a common processor benchmark approach must be used. Currently the most common benchmark is the DMIPS (Dhrystone Million Instructions Per Second) benchmark. The DMIPS benchmark is based on running an algorithm on a targeted processor core to measure its integer processing capabilities within a defined time period.





Xilinx MicroBlaze supports bus clock frequencies up to 150 MHz for which the Virtex FPGA family provides DMIPS up to 150 MHz and Spartan family up to 85 MHz [7]. The processor execution of timing peripheral is out of on-chip memory to ensure maximum processor performance. This benchmark

implementation utilizes 2289 LUTs and achieves an operational speed of 100 MHz. The benchmark performance achieved is optimized with the use of -1 grade of Virtex6 FPGAs. Debugging a design can save weeks design effort and schedule by means of software simulators, real-time software debugger, trace capability and hardware/software logic analyzer triggers. Debugging is performed on the evaluation board via a JTAG bus interface. Xilinx's ChipScope Pro software provides bus analysis and input-output signals trace capability to support FPGA system-level design evaluation and debug [8]. XPS Debug Configuration Wizard automates hardware and software debug configuration tasks common to most designs. The ChipScope Pro tools include several utilities that are integrated into a single application; this provides device configuration, trigger setup, and trace display for ChipScope Pro cores. The ChipScope AXI Monitor Core, for IBA creates a bit stream containing the ChipScope core and software application. The triggering of IBA has depicted the start of timing peripheral captures of inputs at the address 0x73600000- 0x7360FFFF, as shown in Figure 6.



Fig 6: ChipScop IBA analyser trigger captures

This has been earlier verified at runtime debugging stage when the variables were read in binary format from the disassembly window from SDK debugger. Snapshot of the disassembly window is seen in the Figure 7.



Fig 7: Disassembly window in SDK

IJSER © 2013 http://www.ijser.org

Providing proper match units to trigger the input/output signals gives the user a better provision for a virtual hardware platform capable of providing visual feedback within a console-based window supporting emulating system I/O functionality.

The ChipScope ILA analyzer provided from XPS debug wizard provides options to trigger proper match units for the four inputs and outputs, as shown in the Figure 8. The Capture Parameters tab sets the depth of the ILA core. This determines the number of samples that can be stored once the ILA is triggered. Data depth settings are adjusted to determine the impact of selected parameters (samples) on the resources used by the ILA.

| Bus Signal                                                                                                                                                                                       | X                                                                 | 0                                                               | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  | 10880 12160     | 13440 14720    |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|-----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|----------------|
| /tst_IBN                                                                                                                                                                                         | 0                                                                 |                                                                 |                                                                                                                                                                                              |                 |                |
| -/TR_pulse_0807                                                                                                                                                                                  | 0                                                                 |                                                                 |                                                                                                                                                                                              |                 |                |
| /TX_stgnel                                                                                                                                                                                       | 0                                                                 |                                                                 |                                                                                                                                                                                              |                 |                |
| /Window_sta                                                                                                                                                                                      | 0                                                                 |                                                                 |                                                                                                                                                                                              |                 |                |
| /state[3]_X                                                                                                                                                                                      | 0                                                                 |                                                                 |                                                                                                                                                                                              |                 |                |
| /state[3]_X                                                                                                                                                                                      | 0                                                                 |                                                                 |                                                                                                                                                                                              |                 |                |
| /Bean orties                                                                                                                                                                                     | 0                                                                 |                                                                 |                                                                                                                                                                                              |                 |                |
| -/Bem_ocien.                                                                                                                                                                                     | 0                                                                 |                                                                 |                                                                                                                                                                                              |                 |                |
| /Sem_ocien.                                                                                                                                                                                      | 0                                                                 |                                                                 |                                                                                                                                                                                              |                 |                |
| /TTT points                                                                                                                                                                                      | 2                                                                 | 2                                                               | 2                                                                                                                                                                                            | χ               | 0              |
| - /ITT points                                                                                                                                                                                    | 0                                                                 |                                                                 |                                                                                                                                                                                              |                 |                |
|                                                                                                                                                                                                  |                                                                   |                                                                 |                                                                                                                                                                                              |                 |                |
| estation - /۳۳۲ - /۳۳۲<br>Waveform - DEV:1                                                                                                                                                       |                                                                   | vice1 (                                                         | KGOVLK240TJ UNIT:0 Myilao (ila)                                                                                                                                                              |                 |                |
| - 1                                                                                                                                                                                              |                                                                   | vice1 (                                                         | CGVLX2401) UNIT:0 MyILAO (ILA)<br>0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600<br>9 641 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600 | 10880 12160     | 13440 14720    |
| Waveform - DEV:1                                                                                                                                                                                 | MyDev                                                             | vice1 (                                                         | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  | 10880 12160     | 13440 14721    |
| Waveform - DEV:1<br>Bus/Signal                                                                                                                                                                   | MyDev<br>X                                                        | vice1 (J                                                        | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  | 10880 12160     | 13440 14720    |
| Waveform - DEV:1 Bus/Signal /rst_IBUF                                                                                                                                                            | MyDev<br>X                                                        | vice1 (<br>O<br>O                                               | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  | 10880 12160     | 13440 14721    |
| Waveform - DEV:1<br>Bus/Signal<br>/rst_IBUF<br>/TR_pulse_0BUF                                                                                                                                    | MyDev<br>X<br>0                                                   | vice1 ()<br>0<br>0                                              | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  | 10880 12160     | 13440 1472(    |
| Waveform - DEV:1<br>Bus/Signal<br>/rst_IBUF<br>/TR_pulse_OBUF<br>/TX_signal<br>/Window_sta                                                                                                       | MyDev<br>X<br>0<br>1                                              | vice1 (<br>0<br>0<br>1<br>0                                     | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  | 10880 12160     | 13440 14721    |
| Waveform - DEV:1 Bus/Signal /rst_IBUF /TR_pulse_0BUF /TX_signal                                                                                                                                  | MyDev<br>X<br>0<br>1<br>0                                         | vice1 (<br>0<br>1<br>0<br>0                                     | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  | 10880 12160     | 13440 14720    |
| Waveform - DEV:1<br>BUSSignal<br>/rst_IBUF<br>/TR_pulse_OBUF<br>/TX_signal<br>/Window_sta<br>/state[3]_X<br>/state[3]_X                                                                          | MyDev<br>X<br>0<br>1<br>0<br>0                                    | vice1 ()<br>0<br>1<br>0<br>0                                    | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  |                 | 13440 1472(    |
| Waveform - DEV:1<br>BUSSignal<br>/rst_IBUF<br>/TR_pulse_OBUF<br>/TX_signal<br>/Window_sta<br>/state[3]_X<br>/state[3]_X                                                                          | MyDev<br>X<br>0<br>1<br>0<br>0<br>0<br>0                          | vice1 (<br>0<br>0<br>1<br>0<br>0<br>0<br>0                      | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  |                 | 1340 1472(<br> |
| Waveform - DEV:1<br>Bus/Signal<br>/rst_IBUF<br>/TR_pulse_OBUF<br>/TX_signal<br>/%indow_sta<br>/state[3]_X<br>/state[3]_X<br>/state[3]_X                                                          | MyDev<br>X<br>0<br>1<br>0<br>0<br>0<br>0<br>0                     | ice1 ()<br>0<br>1<br>0<br>0<br>0<br>0                           | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  | 10880 12160     | 1340 1472(<br> |
| Waveform-DEV:1<br>BusSignal<br>/tst_IB07<br>/TR_pulse_GB07<br>/TX_signal<br>/state[3]_X<br>/state[3]_X<br>/state[3]_X<br>/state[3]_X<br>/state[3]_X<br>/state[3]_X<br>/state[3]_X<br>/state[3]_X | MyDev<br>X<br>0<br>1<br>0<br>0<br>0<br>0<br>0<br>0<br>0           | vice1 ()<br>0<br>1<br>0<br>0<br>0<br>0<br>0<br>0<br>0           | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600                                                                                                                  | 10880 12160<br> | 1340 1472(<br> |
| Waveform - DEV:1<br>BusSignal<br>/rst_IBUF<br>/TR_pulse_OBUF<br>/TX_signal<br>/Window_sta<br>/state[3]_X<br>/state[3]_X<br>/Bean_orien<br>/Bean_orien                                            | MyDev<br>X<br>0<br>1<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | vice1 ()<br>0<br>1<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 0 640 1280 1920 2560 3200 3840 4480 5120 5760 6400 7040 7680 8320 8960 9600<br>                                                                                                              | 10880 12160<br> |                |

#### Fig 8: ChipScope ILA triggers for corresponding match units

The implementation of the timing control and signal generation controller in the soft processor core is beneficial from a system-oriented design approach and the tradeoffs established between hardware and software overshadows its capability to maximize efficiency and performance. Scalability and programmability of the other designed functional blocks of the digital radar receiver can be practically envisaged when each of them is being implemented as IP cores in the MicroBlaze codesign environment, which is adopted as the future work in this area. It is much easier to design, implement, debug and test an FPGA soft processor-based project rather than a standalone block project. The Fast Simplex Link (FSL) interfaces can further speed up the operation and provide low latencies for the functionality which is again adopted as future work implementation. With latest FPGA hardware design tools, transitioning software bottlenecks from software to hardware is easier since the software C code can be readily adapted into hardware. In general, the future scope of this work focuses building the timing controller on an FSL platform and integrating the other functional blocks of the digital radar receiver onto the MicroBlaze codesign environment and applying hardware /software partitioning algorithms to decrease energy, get the required optimization and increase in efficiency.

## 4 CONCLUSION

Xilinx MicroBlaze provided by FPGA vendors gives a flexibility to configure the processors and enable to build FPGA systems at a quicker and effective pace. By reducing the component count in a design, board size and inventory management can be reduced both of which will save design time and cost. This implementation of the timing control and signal generation unit in the soft processor core is benefited from a systemoriented design approach and the trade-offs established between Hardware and Software to maximize efficiency and performance. As future work, Timing unit can be implemented on an FSL Platform which would speed up the operation and provide low latencies for the functionality. Also, the codesign environment can be expanded by applying Hardware/ Software partitioning algorithms to decrease energy, optimization and increased efficiency.

#### REFERENCES

- R.C. Cofer, Ben Harding, "FPGA Soft Processor Design Considerations," *EETIMES*, http://www.eetimes.com. 2005.
- [2] B.H. Fletcher, "FPGA Embedded Processors: Revealing True System Performance," *Embedded systems conference San Francisco*, pp. 2-18, ETP-367, 2005.
- [3] Yuanbin Wu, Jinwen Li, "The design of Digital Radar Recievers," Proc. IEEE National Radar conference, Syracuse, USA pp. 207-210, 1997.
- [4] R. Jesman, "MicroBlaze Tutorial Creating a simple Embedded system and Adding custom Peripherals using Xilinx EDK Software tool," *Illinois Institute of Technology*,

http://ecasp.ece.iit.edu/tutorials/microblaze\_tutorial.pdf

- [5] Roman Lysecky, Frank Vahid, " A study of the speedups and Competitiveness of FPGA Soft Processor Cores using Dynamic Hardware/ Software Partitioning," Proc. IEEE Computer Society Conference on Design, Automation and Testing, Europe, pp. 18-23, 2005.
- [6] "MicroBlaze Processor Reference Guide Embedded development kit," Xilinx Inc.
- [7] "Embedded system tools Reference Manual EDK 12.4," Xilinx Inc.
- [8] "Getting Started with Embedded system development using Micro-Blaze Processor Spartan-3a FPGAs," *Xilinx Inc.*